<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <main id="app">
        <my-header level="2">测试</my-header>
        <my-p></my-p>
    </main>
</body>
<script src="../vue.min.js"></script>
<script>
    new Vue({
        el: "#app",
        components: {
            // 组件名字：谨慎使用驼峰命名，推荐使用-命名。如果使用驼峰命名，DOM标签需要转化为-命名。
            "my-header": {
                // 注意：组件中的data()一定是一个方法返回一个对象
                data() {
                },
                props: {
                    level: {
                        type: Number,
                        default: 1
                    }
                },
                render(createElement) {
                    return createElement(
                        // 标签名
                        "h" + this.level,
                        // 插槽
                        this.$slots.default
                    )
                }
            },
            "my-p": {
                data() {
                    return {
                        text: "我一个p标签"
                    }
                },
                render(createElement) {
                    return createElement("p",
                        this.text)
                }
            }
        }
    })
</script>

</html>